<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>是什么造就了高级工程师？编写软件还是构建系统 - (power up)</title>
  <meta name="renderer" content="webkit" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>

<meta http-equiv="Cache-Control" content="no-transform" />
<meta http-equiv="Cache-Control" content="no-siteapp" />

<meta name="theme-color" content="#f8f5ec" />
<meta name="msapplication-navbutton-color" content="#f8f5ec">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="#f8f5ec">


<meta name="author" content="Kevin Jiang" /><meta name="description" content="是什么造就了高级工程师？编写软件还是构建系统？ 初级工程师关心编写软件，他们以代码质量、采用最佳实践，采用前沿技术为价值。他们投入大量时间学习" /><meta name="keywords" content="KevinJiang, AI大模型, AI落地, 全栈工程师, Java, Spring Boot" />






<meta name="generator" content="Hugo 0.84.4 with theme even" />


<link rel="canonical" href="http://kevinjiang.info/post/%E6%98%AF%E4%BB%80%E4%B9%88%E9%80%A0%E5%B0%B1%E4%BA%86%E9%AB%98%E7%BA%A7%E5%B7%A5%E7%A8%8B%E5%B8%88%E7%BC%96%E5%86%99%E8%BD%AF%E4%BB%B6%E8%BF%98%E6%98%AF%E6%9E%84%E5%BB%BA%E7%B3%BB%E7%BB%9F/" />
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png">
<link rel="manifest" href="/manifest.json">
<link rel="mask-icon" href="/safari-pinned-tab.svg" color="#5bbad5">



<link href="/sass/main.min.78f8f17bab244b9ee62ad16480c9584d5fc2db06ae20681d1ca225cefd80767c.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.css" integrity="sha256-7TyXnr2YU040zfSP+rEcz29ggW4j56/ujTPwjMzyqFY=" crossorigin="anonymous">


<meta property="og:title" content="是什么造就了高级工程师？编写软件还是构建系统" />
<meta property="og:description" content="是什么造就了高级工程师？编写软件还是构建系统？ 初级工程师关心编写软件，他们以代码质量、采用最佳实践，采用前沿技术为价值。他们投入大量时间学习" />
<meta property="og:type" content="article" />
<meta property="og:url" content="http://kevinjiang.info/post/%E6%98%AF%E4%BB%80%E4%B9%88%E9%80%A0%E5%B0%B1%E4%BA%86%E9%AB%98%E7%BA%A7%E5%B7%A5%E7%A8%8B%E5%B8%88%E7%BC%96%E5%86%99%E8%BD%AF%E4%BB%B6%E8%BF%98%E6%98%AF%E6%9E%84%E5%BB%BA%E7%B3%BB%E7%BB%9F/" /><meta property="article:section" content="post" />
<meta property="article:published_time" content="2022-12-10T10:31:04+08:00" />
<meta property="article:modified_time" content="2022-12-10T10:31:04+08:00" />

<meta itemprop="name" content="是什么造就了高级工程师？编写软件还是构建系统">
<meta itemprop="description" content="是什么造就了高级工程师？编写软件还是构建系统？ 初级工程师关心编写软件，他们以代码质量、采用最佳实践，采用前沿技术为价值。他们投入大量时间学习"><meta itemprop="datePublished" content="2022-12-10T10:31:04+08:00" />
<meta itemprop="dateModified" content="2022-12-10T10:31:04+08:00" />
<meta itemprop="wordCount" content="1275">
<meta itemprop="keywords" content="高级软件工程师,软件工程," /><meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="是什么造就了高级工程师？编写软件还是构建系统"/>
<meta name="twitter:description" content="是什么造就了高级工程师？编写软件还是构建系统？ 初级工程师关心编写软件，他们以代码质量、采用最佳实践，采用前沿技术为价值。他们投入大量时间学习"/>

<!--[if lte IE 9]>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/classlist/1.1.20170427/classList.min.js"></script>
<![endif]-->

<!--[if lt IE 9]>
  <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
<![endif]-->

</head>
<body>
  <div id="mobile-navbar" class="mobile-navbar">
  <div class="mobile-header-logo">
    <a href="/" class="logo">(Power up)</a>
  </div>
  <div class="mobile-navbar-icon">
    <span></span>
    <span></span>
    <span></span>
  </div>
</div>
<nav id="mobile-menu" class="mobile-menu slideout-menu">
  <ul class="mobile-menu-list">
    <a href="/">
        <li class="mobile-menu-item">首页</li>
      </a><a href="/post/">
        <li class="mobile-menu-item">归档</li>
      </a><a href="/tags/">
        <li class="mobile-menu-item">标签</li>
      </a><a href="/categories/">
        <li class="mobile-menu-item">分类</li>
      </a><a href="/resume/">
        <li class="mobile-menu-item">简历</li>
      </a>
  </ul>

  


</nav>

  <div class="container" id="mobile-panel">
    <header id="header" class="header">
        <div class="logo-wrapper">
  <a href="/" class="logo">(Power up)</a>
</div>





<nav class="site-navbar">
  <ul id="menu" class="menu">
    <li class="menu-item">
        <a class="menu-item-link" href="/">首页</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/post/">归档</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/tags/">标签</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/categories/">分类</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/resume/">简历</a>
      </li>
  </ul>
</nav>

    </header>

    <main id="main" class="main">
      <div class="content-wrapper">
        <div id="content" class="content">
          <article class="post">
    
    <header class="post-header">
      <h1 class="post-title">是什么造就了高级工程师？编写软件还是构建系统</h1>

      <div class="post-meta">
        <span class="post-time"> 2022-12-10 </span>
        
          <span class="more-meta"> 约 1275 字 </span>
          <span class="more-meta"> 预计阅读 3 分钟 </span>
        
      </div>
    </header>

    <div class="post-toc" id="post-toc">
  <h2 class="post-toc-title">文章目录</h2>
  <div class="post-toc-content always-active">
    <nav id="TableOfContents">
  <ul>
    <li><a href="#是什么造就了高级工程师编写软件还是构建系统">是什么造就了高级工程师？编写软件还是构建系统？</a></li>
  </ul>
</nav>
  </div>
</div>
    <div class="post-content">
      <h2 id="是什么造就了高级工程师编写软件还是构建系统">是什么造就了高级工程师？编写软件还是构建系统？</h2>
<p>初级工程师关心编写软件，他们以代码质量、采用最佳实践，采用前沿技术为价值。他们投入大量时间学习新技术。对他们来说，最终目标是创建优雅、高性能、可维护的软件。</p>
<p>高级工程师关心的是构建系统。 对他们来说，创建软件只是其中一个步骤。 首先，他们会质疑是否需要构建软件。他们会问将要解决什么问题，为什么解决这些问题很重要。他们询问谁将使用该软件以及使用的规模。他们考虑软件将在哪里运行，以及他们将如何监控它是否正常工作。 他们还决定如何衡量软件是否真正解决了它应该解决的问题。</p>
<!-- raw HTML omitted -->
<p>构建系统比构建软件要难得多。 甚至可能会使人不自在。作为一名工程师，呆在原地，并专注于完善这段漂亮的代码是非常诱人的。人们很容易认为确定需求是产品经理的工作，而部署软件应该由运营团队负责。但是，通过参与构建系统的这些方面，您会带来很多价值。您是最了解您的软件的人，也是您最了解如何运行它、如何监控它、扩展它有多容易等等。更重要的是，您的分析思维和解决问题的能力，使您有洞察力关于产品要求非常有价值。</p>
<p>技术专长当然非常重要。优雅、高性能、可维护的软件更易于运行，中断次数更少，更易于扩展和推理。然而，它可能解决了一个错误的商业问题。或者客户不喜欢它是因为性能问题，而您甚至不知道，因为您没有监控它。</p>
<p>让我们更深入地了解构建系统的一部分事项（非详尽）列表：</p>
<ul>
<li>定义需求-与产品经理合作，了解他们想要解决的问题；也许您会有更好的办法，更少的投入；</li>
<li>定义NFR（non-functional requirements）-与PM讨论非功能需求-系统应处理多少用户，性能、吞吐量和延迟的要求是什么？是否有任何安全或法规遵从性考虑？我们需要审计吗？期望的可用性是什么？</li>
<li>规划迭代-与您的团队一起提出实施计划；确保您定义了小的、可演示的里程碑，以便您能够尽快开始交付价值；与PM（Product Manager 产品经理）就里程碑达成一致。</li>
<li>确定依赖关系-确保您确定了团队之外的所有依赖关系，并与EM（Engagement Manager 项目经理）或团队直接合作，为他们获取一些ETA（预计到达时间）。相应地调整里程碑。</li>
<li>测试-根据公司的运营方式，与团队或QE（Quality Engineer 质量工程师）团队一起决定测试策略。同意推出所需的质量阈值（例如，没有未解决的主要错误或测试覆盖率超过X%）。</li>
<li>部署-与您的团队一起决定如何部署系统。您需要一些新的基础设施吗？还是可以重用现有的基础设施？如果您需要很多，费用是多少？</li>
<li>可观察性-决定如何监控系统的运行状况，并建立解决生产问题的流程（例如随叫随到的团队）。使用第三方解决方案<!-- raw HTML omitted -->设置监控器和仪表板。</li>
<li>推广沟通-一旦您与团队和项目经理商定了推广日期，请确保所有利益相关者都知道。检查是否需要任何文档更改。</li>
<li>衡量成功-决定衡量项目是否成功的指标。有人在使用新系统吗？用户是否能够完成他们的任务？<!-- raw HTML omitted --></li>
</ul>
<p>我见过很多工程师，他们坚信，提升职业生涯的唯一途径是投资于他们的技术技能。虽然这很重要，但对公司来说唯一重要的是你对业务的影响有多大。将重点从软件转移到系统将使您在增加软件方面处于更好的位置。</p>

    </div>

    <div class="post-copyright">
  <p class="copyright-item">
    <span class="item-title">文章作者</span>
    <span class="item-content">Kevin Jiang</span>
  </p>
  <p class="copyright-item">
    <span class="item-title">上次更新</span>
    <span class="item-content">
        2022-12-10
        
    </span>
  </p>
  
  <p class="copyright-item">
    <span class="item-title">许可协议</span>
    <span class="item-content"><a rel="license noopener" href="https://creativecommons.org/licenses/by-nc-nd/4.0/" target="_blank">CC BY-NC-ND 4.0</a></span>
  </p>
</div>
<div class="post-reward">
  <input type="checkbox" name="reward" id="reward" hidden />
  <label class="reward-button" for="reward">赞赏支持</label>
  <div class="qr-code">
    
    <label class="qr-code-image" for="reward">
        <img class="image" src="/img/wechat_pay_1242x1242.jpg">
        <span>微信打赏</span>
      </label>
    <label class="qr-code-image" for="reward">
        <img class="image" src="/img/alipay_600x600.jpg">
        <span>支付宝打赏</span>
      </label>
  </div>
</div><footer class="post-footer">
      <div class="post-tags">
          <a href="/tags/%E9%AB%98%E7%BA%A7%E8%BD%AF%E4%BB%B6%E5%B7%A5%E7%A8%8B%E5%B8%88/">高级软件工程师</a>
          <a href="/tags/%E8%BD%AF%E4%BB%B6%E5%B7%A5%E7%A8%8B/">软件工程</a>
          </div>
      <nav class="post-nav">
        <a class="prev" href="/post/linux/%E4%BD%BF%E7%94%A8mobaxterm%E5%81%9A%E7%AB%AF%E5%8F%A3%E8%BD%AC%E5%8F%91/">
            <i class="iconfont icon-left"></i>
            <span class="prev-text nav-default">使用MobaXterm做端口转发</span>
            <span class="prev-text nav-mobile">上一篇</span>
          </a>
        <a class="next" href="/post/mysql/mysql%E5%AF%BC%E5%85%A5csv%E6%95%B0%E6%8D%AE/">
            <span class="next-text nav-default">快速上手！如何使用MySQL导入CSV格式数据</span>
            <span class="next-text nav-mobile">下一篇</span>
            <i class="iconfont icon-right"></i>
          </a>
      </nav>
    </footer>
  </article>
        </div>
        

  

  

      </div>
    </main>

    <footer id="footer" class="footer">
      <div class="social-links">
      <a href="mailto:wenlin1988@126.com" class="iconfont icon-email" title="email"></a>
      <a href="https://www.linkedin.com/in/%E6%96%87%E6%9E%97-%E8%92%8B-0a3204126/" class="iconfont icon-linkedin" title="linkedin"></a>
      <a href="https://github.com/kevindragon" class="iconfont icon-github" title="github"></a>
  <a href="http://kevinjiang.info/index.xml" type="application/rss+xml" class="iconfont icon-rss" title="rss"></a>
</div>

<div class="copyright">
  <span class="power-by">
    由 <a class="hexo-link" href="https://gohugo.io">Hugo</a> 强力驱动
  </span>
  <span class="division">|</span>
  <span class="theme-info">
    主题 -
    <a class="theme-link" href="https://github.com/olOwOlo/hugo-theme-even">Even</a>
  </span>

  

  <span class="copyright-year">
    &copy;
    2015 -
    2023<span class="heart"><i class="iconfont icon-heart"></i></span><span>Kevin Jiang</span>
    <a href="https://beian.miit.gov.cn/" target="_blank">湘ICP备2022022745号</a>
  </span>
</div>

    </footer>

    <div class="back-to-top" id="back-to-top">
      <i class="iconfont icon-up"></i>
    </div>
  </div>
  
  <script src="https://cdn.jsdelivr.net/npm/jquery@3.2.1/dist/jquery.min.js" integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/slideout@1.0.1/dist/slideout.min.js" integrity="sha256-t+zJ/g8/KXIJMjSVQdnibt4dlaDxc9zXr/9oNPeWqdg=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.js" integrity="sha256-XVLffZaxoWfGUEbdzuLi7pwaUJv1cecsQJQqGLe7axY=" crossorigin="anonymous"></script>



<script type="text/javascript" src="/js/main.min.c99b103c33d1539acf3025e1913697534542c4a5aa5af0ccc20475ed2863603b.js"></script>
  <script type="text/javascript">
    window.MathJax = {
      tex: {
        inlineMath: [['$','$'], ['\\(','\\)']],
        tags: 'ams',
        }
    };
  </script>
  <script type="text/javascript" async src="/lib/mathjax/es5/tex-mml-chtml.js"></script>

<script id="baidu_analytics">
  var _hmt = _hmt || [];
  (function() {
    if (window.location.hostname === 'localhost') return;
    var hm = document.createElement("script"); hm.async = true;
    hm.src = "https://hm.baidu.com/hm.js?b73ff6d4afc4af9e582d8a5dc068bab9";
    var s = document.getElementsByTagName("script")[0];
    s.parentNode.insertBefore(hm, s);
  })();
</script>






</body>
</html>
